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BACKGROUND 



1. Field of the Invention 

This invention relates to data communications in a computer system, and 
more specifically, to a memory translator hub designed to provide a memory bus 
from a memory channel. 

2. Background Information 

Computer systems rely heavily upon Dynamic Random Access Memories 
("DRAMs") to implement system memories due to their simplicity, affordability and 
memory density. However, it is increasingly difficult to design memory systems that 
satisfy the size and performance requirements for modern computer systems using 
DRAMs connected by conventional bus architectures. To overcome these 
limitations, a memory subsystem can be constructed using a memory channel 
architecture. Intelligent memory devices are connected by a narrow, high-speed 
bus, termed a channel. Packets of information are transmitted on the memory 
channel to communicate between the memory controller and the memory devices. 
Direct Rambus™ architecture using Rambus® channels is an example of a memory 
subsystem using a memory channel architecture. 

As a new technology, the cost of components, such as Rambus DRAM 
(RDRAM™), for memory channel subsystems is high and supplies are uncertain. 
Memory channel devices require a completely different memory interface from 
conventional memory devices. Memory channel devices are not compatible with 
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previous memory controllers which support more conventional memory components 
such as Synchronous DRAM (SDRAM) components using a memory bus. 

During the transition to computer systems using memory channel 
subsystems, it would be desirable to build computer systems that can use either a 
conventional memory bus subsystem or a memory channel subsystem. Memory 
controllers that can support two or more conventional memory technologies on a 
single memory bus are known. For example, United States Patent 5,893,136, 
assigned to Intel Corporation, describes a memory controller for independently 
supporting synchronous and asynchronous DRAM memories. It is possible to 
support multiple conventional memory technologies with a single memory controller 
because the memories use a memory bus with the same electrical signaling levels 
and similar signaling arrangements. 

Memory channel architectures use different electrical signaling levels and a 
novel signaling arrangement. This precludes control of conventional SDRAM 
memory subsystems with memory channel controllers. Accordingly, there is a need 
for a memory translator that allows a memory bus subsystem to be connected to a 
memory channel controller. 
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SUMMARY 



A memory translation hub comprising a memory channel interface, a memory 
bus interface, and a command generator coupled to the memory channel interface 
and to the memory bus interface. The memory channel interface receives a 
memory control packet from a memory channel. The memory bus interface 
provides a memory bus. The command generator causes the memory bus interface 
to provide memory control signals on the memory bus responsive to the memory 
control packet. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram of a computer system that includes an 
embodiment of a memory subsystem according to the invention. 

Figure 2 is a block diagram of another embodiment of a memory subsystem 
according to the invention. 

Figure 3 is a block diagram of an embodiment of a Memory Translator Hub. 
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DETAILED DESCRIPTION 

The present invention provides a method and apparatus to connect a 
memory bus, such as an SDRAM bus, to a memory channel, such as a Rambus® 
channel, through a translation device, which will be termed a Memory Translator 
5 Hub (MTH). The MTH interprets a protocol on the physical memory channel as 
defined by the invention and generates appropriate memory control signals to 
provide a memory bus for a conventional memory array such as an SDRAM array. 
The control signals on the memory channel are used for sending commands as 
provided by the invention from the memory channel controller, which will be termed 
10 a Memory Control Hub (MCH), to the MTH. While the data signals on the memory 
channel are used for data transfer between the MCH and the MTH, the protocol 
used between the MCH and the MTH is different from the memory channel protocol. 
Multiple MTHs can be connected on the memory channel and each MTH can 
support multiple rows of memory devices. The MTH supports interleaved and non- 
15 interleaved modes of operation for the conventional memory devices. Data is 
provided in 8 byte packets in non-interleaved mode and in 1 6 byte packets in 
interleaved mode. Embodiments of the invention will be described for providing a 
memory bus to support SDRAM memory devices from a memory channel that 
embodies the Direct Rambus™ architecture. It will be understood by those skilled 
20 in the art that the invention is applicable to other memory channel architectures and 
that the invention can provide memory buses that support other memory devices. 
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Figure 1 illustrates a computer system that includes an embodiment of the 
invention. A controller hub 110 is used to interconnect a processor 130, a video 
display terminal (VDT) 144, an input/output (I/O) subsystem, and a memory 
subsystem. The controller hub 110 includes interconnected interface sections that 

5 provide the external connections. The processor 130 is connected to the controller 
hub 1 10 by a system bus 132 which is connected through the Host Interface 134. 
The VDT 144 is connected through the Accelerated Graphics Port (AGP) Interface 
140. The I/O subsystem provides a Peripheral Component Interconnect (PCI) bus 
152 that connects I/O devices 154 through a PCI Bus Interface 150. The memory 

10 subsystem is connected through a Memory Control Hub (MCH) 120. The 

interconnection of the interface sections in the controller hub 110 allows the memory 
subsystem to handle memory requests from the processor 130, the VDT 144, and 
the devices 154 on the PCI bus 152. 

The MCH 120 provides a memory channel 122, such as a Rambus® channel, 
15 to support the memory channel architecture, such as the Direct Rambus™ 

architecture. Direct Rambus™ architecture provides a memory channel architecture 
that includes a physical channel structure, signaling levels, and a packet protocol. 
Direct Rambus™ architecture is further described in "Rambus® Technology 
Overview," DL-0040-00, Rambus Inc., February 12, 1999, which is incorporated by 
20 reference. 
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A number of slots are provided on the memory channel 122 to receive 
memory channel devices 124, such as Rambus Inline Memory Modules (RIMMs™). 
The memory channel 122 differs significantly from conventional memory buses such 
as those used to connect SDRAMs. Conventional memory buses are wider (use 
5 more pins) than the memory channel. Conventional memory buses use CMOS 
signaling levels while much of the signaling on the memory channel uses high- 
speed signals with small voltage swings, such as Rambus® Signaling Levels (RSL). 
The memory channel forms a continuous path through the memory devices rather 
than providing tapped connections onto a continuous bus. 

10 The protocol for controlling memory channel devices is also significantly 

different from the protocol for SDRAM. The memory channel protocol is based on 
packet communication between the MCH 120 and the memory channel devices 124. 
The protocol to control SDRAMs on DIMMs requires separate address and data 
lines and includes point to point control signals from the memory controller to device 

15 rows. The SDRAM architecture is further described in "JEDEC Standard No. 21-C, 
Release 4," which is incorporated by reference. 

As shown in Figure 1 , the MTH 100 is connected to the memory channel 122 
and provides an SDRAM bus 102 and SDRAM control signals 106. Both the 
memory channel 122 and the SDRAM bus 102 require termination (not shown). If 
20 only the memory channel is being used, the DIMM sockets are left unpopulated. If 
only SDRAM memory is being used, the memory device sockets are filled by 
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continuity modules to maintain the memory channel 122. Figure 2 illustrates 
another memory subsystem that uses multiple MTHs 100 that embody the invention. 
For clarity, memory device sockets on the memory channel are not shown in Figure 
2. 

5 Figure 3 shows a block diagram of an MTH 100 that embodies the invention. 

The MTH 100 receives Memory Control Packets (MCPs) from the MCH 120 through 
the memory channel 122. The MCPs utilize a protocol defined by the invention for 
the purpose of accessing SDRAM memory through the memory channel. The 
MCPs are received by the memory channel interface circuits 300 and provided to an 

10 MCP decoder and SDRAM command generator 302. The MCPs are decoded and 
appropriate signals are driven on the memory bus 102 and control lines 106 to carry 
out the command. It should be noted that the memory channel 122 will generally 
operate at a higher clock rate that the memory bus 102. In one embodiment, four 
channel cycles occur during one memory bus cycle. This may require the MCH to 

15 time the transmission of packets on the channel based on the memory bus cycle 
time. 

For read commands, the MTH 100 waits for the data to come back from the 
SDRAMs 1 04 and then converts the data to appropriate data packets to be sent to 
the MCH 120 via the memory channel 122. The read data is received by the 
20 SDRAM interface receivers 312 and provided to the read buffer, packetizer, and 
clock logic 306 which assembles the read data as required by the memory channel 
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interface 300. The MTH 100 is aware of the CAS Latency (CL) for the SDRAMs and 
times the capture of data from the SDRAMs appropriately. 

For write commands, the MTH 100 contains a write buffer and write retire 
logic 304 that temporarily stores the write data and control from the MCH 120. The 
5 MTH 100 stores this data to the SDRAM 104 when the write buffer and write retire 
logic 304 detect an implied or explicit retire command from the MCH 120 by 
generating the required SDRAM signals. 

The MTH 100 does a current calibration and temperature calibration of the 
memory channel 122 upon receiving the appropriate commands from the MCH 120. 
10 The MTH 100 contains registers for configuration and control. These registers are 
accessed through a low-speed signaling interface provided by the memory channel 
122. An MTH_RST# signal can be used to cause a hardware reset of the MTH. A 
TESTIN# signal can be used to place the MTH into a diagnostic mode. 

Memory Control Packets (MCPs) that embody the present invention are 
15 transmitted to the MTH over the portion of the memory channel used to transmit 
commands to memory channel devices. In an exemplary memory subsystem that 
uses a Rambus® channel, 8 request signals, RQ[7: 0], are available on the channel 
to send a command from the MCH to the MTH. The MCP is sent over the memory 
channel in two channel clocks (RCIks). To increase the speed of data 
20 communication, packet information is clocked by both the rising and falling clock 
edges. Therefore, the MCPs contains 4 data units. There are 32 bits (4 x 8) in an 
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MCP packet. In one embodiment of invention, each MCP must be separated by at 
least two unused clock cycles. In another embodiment of invention, no separation 
by unused clocks is required and each MCP can be sent back to back. 

MCPs are generally directed to a targeted memory row by a device ID field, 
D[3:0], in the MCP. The MTH 100 maintains an MTH ID value and an MTH ID mask 
to determine if the memory row targeted by the device ID field is coupled to the 
MTH. The device ID is masked by the MTH ID mask and then compared to the 
MTH ID value. If the masked device ID is equal to the MTH ID value, the MTH will 
respond to the MCP. 

The first two bits, ST and SF, of each MCP indicate the framing of a packet 
and specify what kind of command packet it is. The encoding of ST and SF is as 
follows: 



ST 


SF 


Operation 


0 


0 


No Framing 


0 


1 


Frame an Activate Command 


1 


0 


Frame a Read/Write Command 


1 


1 


Frame an Extended Command 



An Activate Command packet has the following format: 



Cycle 0 



Cycle 1 



+ 



RQ6 



RQ7 



SF = 1 



ST = 0 



x 



R[12] 



R[5] 
R[4] 



x 



x 
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RQ5 


r 


R[11l 

L J 


R[3] 

L J 


x 


RQ4 


D[3] 


R[10] 


R[2] 


B[0] 


RQ3 


D[2] 


R[9] 


R[1] 


B[1] 


RQ2 


D[1] 


R[8] 


R[0] 


DBM[3] 


RQ1 


D[0] 


R[7] 


r 


DBM[2] 


RQO 


r 


R[6] 


r 


X 



x = don't care 

r = reserved, logical 0 

D[3:0] = Specifies the targeted SDRAM row. 
R[12:0] = Specifies the SDRAM Row address 



5 B[1 :0] = Specifies the SDRAM bank address 

DBM[3:2] = Specifies the device ID mask bits 

The two device ID mask bits, DBM[3:2], are included in the Activate 
Command packets to allow more than one MTH to pre-charge or activate a page in 
its specified SDRAM row in interleaved mode. This allows the memory controller to 

10 treat two interleaved pages as a single, larger page. The larger page enables back- 
to-back interleaved reads and writes for page hit, miss and empty. These bits are 0 
in non-interleaved mode. These bits are used to enable masking out one of the 
upper two bits of the device ID (D[3], D[2]) during MTH SDRAM row decode. When 
the device bit mask is written to 1 , the MTH comparison for the corresponding 

15 device bit is always TRUE, i.e. when DBM[3] = 1 , the value of D[3] always matches 
in all MTHs on the bus regardless of the programming of the MTH ID MASK and 
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only bits D[2:0] are used to select the targeted memory row. Similarly, when DBM[2] 
= 1, the value of D[2] always matches in all MTHs on the bus regardless of the 
programming of the MTH ID MASK and only bits D[3, 1 :0] are used to select the 
targeted memory row. The device ID mask bits are used for pre-charge and activate 
commands. 

An MTH that receives an Activate Command packet targeted to a memory 
row supported by the MTH drives the bits provided by the MCP row field R[12:0] 
onto the multiplexed address lines A[12:0] and the MCP bank field B[1 :0] onto bank 
select lines BA[1 :0]. The row address select, RAS#, signal is enabled and the 
appropriate chip select, S#[N], is enabled to transfer the row and bank selection 
addresses to the targeted memory device. 

A Read/Write Command packet has the following format: 



Cycle 0 Cycle 1 

+ - + 



RQ7 


ST = 1 


X 


C[5] 


X 


RQ6 


SF = 0 


X 


C[4] 


X 


RQ5 


R/W 


C[10] 


C[3] 


X 


RQ4 


D[3] 


AP 


C[2] 


B[0] 


RQ3 


D[2] 


C[9] 


C[1] 


B[1] 


RQ2 


D[1] 


C[8] 


C[0] 


r 


RQ1 


D[0] 


C[7] 


r 


r 


RQO 


r 


C[6] 


r 


X 



x = don't care 

r = reserved, logical 0 
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R/W = 0 for Read, 1 for Write 

D[3:0] = Specifies the targeted SDRAM row. 

C[10:0} = Specifies the SDRAM Column address 

AP = 0 for auto pre-charge disabled, 1 for auto pre-charge enabled 

5 B[1 :0] = Specifies the SDRAM bank address 

An MTH that receives a Read or Write Command packet targeted to a 
memory row supported by the MTH drives the bits provided by the MCP column field 
C[10:0] onto the multiplexed address lines A[1 1, 9:0], the auto pre-charge flag AP 
onto address line A[10], and the MCP bank field B[1 :0] onto bank select lines 
10 BA[1 :0]. The column address select, CAS#, signal is enabled and the appropriate 
chip select, S#[N], is enabled to transfer the column and bank selection addresses 
to the targeted memory device. For a Write Command, the write enable signal WE# 
is also enabled. 

Read data is received from the memory bus 102 by the read buffer, 
15 packetizer, and clock logic 306 which packetizes the read data and causes it to be 
transmitted on the memory channel 122. 

Write data is received from the memory channel 122 by the write buffer and 
write retire logic 304 which temporarily stores the write data and control from the 
MCH 120. In one embodiment, the write buffer can store up to two write commands 
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from the MCH. In one embodiment, the write data packet is transmitted two memory 
bus cycles after the Write Command packet is transmitted. The write retire logic 
transmits this data to the memory devices 104 on the memory bus 102 when the 
write retire logic detects an implied or explicit retire command. The write retire logic 
places the write data on the memory bus data lines DQ[63:0], any error correction 
information on the check bit lines CB[15:0], and the addressing and control signal on 
the memory bus as described above. 

Extended Command packets begin with ST = 1 , SF = 1 . If the next bit, RQ5 
in the first half of cycle 0, is 1 , the Extended Command is Retire with Mask. 
Otherwise, the Extended Command is selected by the operand bits in the MCP. 

A Retire with Mask Extended Command packet has the following format: 
Cycle 0 Cycle 1 







+ 




+ 


RQ7 
RQ6 
RQ5 


ST = 1 

SF = 1 

MASK = 
1 


MA[7] 
MA[6] 
MA[5] 


MB[7] 
MB[6] 
MB[5] 


X 
X 
X 


RQ4 
RQ3 
RQ2 
RQ1 
RQO 


D[3] 
D[2] 
D[1] 
D[0] 
0 


MA[4] 
MA[3] 
MA[2] 
MA[1] 
MA[0] 


MB[4] 
MB[3] 
MB[2] 
MB[1] 
MB[0] 


X 
X 

r 
r 

X 



x = don't care 

r = reserved, logical 0 



D[3:0] = Specifies the targeted SDRAM row. 
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MA[7:0] = Byte Masks for DQA bus. 

MB[7:0] = Byte Masks for DQB bus. 

Data is provided in 8 byte packets in non-interleaved mode and in 1 6 byte 
packets in interleaved mode. Retire with Mask allows a partial write of only those 
bytes selected by the byte masks. For a partial write in one embodiment of the 
invention, the Write Command packet is transmitted on the memory channel 122 in 
one memory bus cycle, the Retire with Mask packet is transmitted in the following 
memory bus cycle, and the write data packet is transmitted in the next following 
memory bus cycle. The MCP mask bits MA[7:0] and MB[7:0] are placed onto 
memory bus lines DQMB[7:0] when the correspond write data is placed on the 
memory bus 102. 

A Pre-charge Extended Command packet has the following format: 

Cycle 0 Cycle 1 

- + - + 

RQ7 ST= 1 OP[8] = 0 OP[5] = 0 OP[2] = 0 
RQ6 SF = 1 OP[7] = 0 OP[4] = 0 OP[1] = 0 
RQ5 MASK = OP[6] = 0 OP[3] = 0 OP[0] = 1 



0 

RQ4 D[3] V x B[0] 

RQ3 D[2] x x B[1] 

RQ2 D[1] x x DBM[3] 

RQ1 D[0] x x DBM[2] 

RQO BRD xxx 
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x = don't care 

r = reserved, logical 0 

D[3:0] = Specifies the targeted SDRAM row. 

BRD = 0 for Addressed, execute to the SDRAM row specified by D[3:0]; 
1 for Broadcast, all MTHs execute command to all SDRAM rows. 

V = 1 for pre-charge all banks. 

B[1 :0] = Specifies the SDRAM bank address 

DBM[3:2] = Specifies the device ID mask bits as described above for Activate 

An MTH that receives a Pre-charge Command packet targeted to a memory 
row supported by the MTH drives the MCP bank field B[1 :0] onto bank select lines 
BA[1:0]. The row address select, RAS#, and write enable WE# signals are enabled, 
address line A[10] is driven low and the appropriate chip select, S#[N], is enabled to 
pre-charge the selected bank of the targeted memory device. For a broadcast pre- 
charge, BRD = 1 , the device ID field D[3:0] and the bank field B[1 :0] are ignored. 
The row address select, RAS#, and write enable WE# signals are enabled, address 
line A[10] is driven high and the all chip selects, S#[N], are enabled to pre-charge 
the all banks of all memory devices. 

The remaining Service Extended Command packets have the following format: 

Cycle 0 Cycle 1 

- + - + 
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RQ7 


ST = 1 


OP[8] 


OP[5] 


OP[2] 


RQ6 


SF = 1 


OP[7] 


OP[4] 


OP[1] 


RQ5 


0 


OP[6] 


OP[3] 


OP[0] 


RQ4 


D[3] 


r 


X 


B[0] 


RQ3 


D[2] 


X 


X 


B[1] 


RQ2 


D[1] 


X 


X 


r 


RQ1 


D[0] 


X 


X 


r 


RQO 


BRD 


X 


X 


X 



x = don't care 

r = reserved, logical 0 



OP[8:0] = Specifies the operations to be performed. 
D[3:0] = Specifies the targeted SDRAM row. 

BRD = 0 for Addressed, execute to the SDRAM row specified by D[3:0]; 
1 for Broadcast, all MTHs execute command to all SDRAM rows. 

B[1 :0] = Specifies the SDRAM bank address 



The operand bits, OP[8:0], are interpreted as follows: 



OP8 


OP7 


OP6 


OP5 


OP4 


OP3 


OP2 


OP1 


OPO 


Operation 


0 


0 


0 


0 


0 


0 


0 


0 


0 


No Op (No operation 
performed by MTH) 


0 


0 


0 


0 


0 


0 


0 


0 


1 


Pre-charge 


0 


0 


0 


0 


0 


0 


0 


1 


0 


Refresh 


0 


0 


0 


0 


0 


0 


1 


0 


0 


Self Refresh Entry 


0 


0 


0 


0 


0 


1 


0 


0 


0 


Self Refresh Exit 


0 


0 


0 


0 


1 


0 


0 


0 


0 


Power-down Entry 
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0 0 


0 


1 


0 




0 


0 


0 


0 


Power-down Exit 


0 0 


1 


0 


0 




0 


0 


0 


0 


Clock Stop 


0 1 


0 


0 


0 




0 


0 


0 


0 


Current Calibrate 
and Sample 


1 0 


0 


0 


0 




0 


0 


0 


0 


Temperature 
Calibrate 


A No Op in two channel cycles followed by two idle cycles is used to 


synchronize the MTHs 100. The synchronization cycles are as follows: 




Cycle 0 
- + 




Cycle 1 


+ 




Cycle 2 


Cycle 3 
+ - + 


RQ7 


1 


0 




0 




0 


0 




0 0 0 


RQ6 


1 


0 




0 




0 


0 




0 0 0 


RQ5 


0 


0 




0 




0 


0 




0 0 0 


RQ4 


0 


0 




0 




0 


0 




0 0 0 


RQ3 


0 


0 




0 




0 


0 




0 0 0 


RQ2 


0 


0 




0 




0 


0 




0 0 0 


RQ1 


0 


0 




0 




0 


0 




0 0 0 


RQO 


1 


0 




0 




0 


0 




0 0 0 



The Current Calibrate and Sample command causes the MTH to initiate a 
current calibrate process of its channel interface. The Temperature Calibrate 
command causes the MTH to initiate a temperature calibration process of its 
channel interface. 

The following table summarizes the memory bus signals that are generated 
by the MTH in response to the various command packets: 
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Function SCLK SCLK CKE CKE CS# RAS# CAS# WE# A11 A10 BA[1:0] A9-A0 

n n-1 n n-1 



NOP 


R 


R 


H 


X 


L 


H 


H 


H 


X 


X 


X 


X 


Read 


R 


R 


H 


X 


L 


H 


L 


H 


V 


L 


V 


V 


Read with auto- 
precharge 


R 


R 


H 


X 


L 


H 


H 


V 


V 


H 


V 


V 


Write 


R 


R 


H 


X 


L 


H 


L 


L 


V 


L 


V 


V 


Write with auto- 
precharge 


R 


R 


H 


X 


L 


H 


L 


L 


V 


H 


V 


V 


Bank Activate 


R 


R 


H 


X 


L 


L 


H 


H 


V 


V 


V 


V 


Precharge 
selected bank 


K 


K 


M 

n 


X 


1 

L 


1 

L 


U 

n 


1 

L 


V 


L 


\/ 

V 


X 


Precharge all 
banks 


R 


R 


H 


X 


L 


L 


■ i 
H 


L 


X 


i i 

H 


X 


X 


Refresh 


R 


R 


H 


H 


L 


L 


L 


H 


X 


X 


X 


X 


Self Refresh 
Entry 


R 


R 


H 


L 


L 


L 


L 


H 


X 


X 


X 


X 


Self Refresh 

1 — , AX. 

Exit 


R 


R 


L 


H 


H 


X 


X 


X 


X 


X 


X 


X 


Power-down 
Entry 


K 


K 


LI 

n 


i 

L 


rt 


V 
A 


A 


v 
A 


v 
A 


v 
A 


v 
A 


v 
A 


Power-down 
Exit 


R 


R 


L 


H 


H 


X 


X 


X 


X 


X 


X 


X 


Mode Register 
Set 


R 


R 


H 


X 


L 


L 


L 


L 


L 


L 


V 


V 


Clock Stop 


R 


L 


X 


X 


X 


X 


X 


X 


X 


X 


X 


X 



x = Don't care, H = Logic high, L = Logic Low, 
R = clock running, V = Valid address 
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The internal logic of the MTH 100-including the 302, the write buffer and 
write retire logic 304, the read buffer, packetizer, and clock logic 306-may be 
implemented in any form of logic, as will be readily understood by those skilled in 
the art. The internal logic may include, but is not limited to, combinatorial logic, state 
machines, programmable logic, and hybrid combinations of these types of logic and 
others. Programmable logic includes logic that is programmed during manufacture 
and logic that can be programmed by various means after the MTH is in service. 

While certain exemplary embodiments have been described and shown in the 
accompanying drawings, it is to be understood that such embodiments are merely 
illustrative of and not restrictive on the broad invention, and that this invention not be 
limited to the specific constructions and arrangements shown and described, since 
various other modifications may occur to those ordinarily skilled in the art. 
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CLAIMS 



What is claimed is: 



1 1 . A memory translation hub comprising: 

2 a memory channel interface that receives a memory control packet from a 

3 memory channel; 

4 a memory bus interface that provides a memory bus; and 

5 a command generator coupled to the memory channel interface and to the 

6 memory bus interface, the command generator causing the memory 

7 bus interface to provide memory control signals on the memory bus 

8 responsive to the memory control packet. 

1 2. The memory translation hub of claim 1 wherein the memory channel includes 

2 a control portion and a data portion, the memory channel interface receiving a 

3 memory control packet only from the control portion of the memory channel. 

1 3. The memory translation hub of claim 1 wherein the memory control packet 

2 includes command flag bits that indicate that the memory control packet is 

3 one of an activate command, a read/write command, and an extended 

4 command. 

1 4. The memory translation hub of claim 3 wherein the memory control packet 

2 specifies a memory row, a memory row address, a memory bank address, 
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3 and a device identification mask if the memory control packet is the activate 

4 command. 

1 5. The memory translation hub of claim 3 wherein the memory control packet 

2 specifies a memory row, a memory column address, and a memory bank 

3 address, if the memory control packet is the read/write command. 

1 6. The memory translation hub of claim 3 wherein, if the memory control packet 

2 is the extended command, the memory control packet includes extended flag 

3 bits that indicate that the memory control packet is one of a retire with mask 

4 command, a pre-charge command, and a service command. 

1 7. The memory translation hub of claim 6 wherein the memory control packet 

2 specifies a memory row, and a byte mask, if the memory control packet is the 

3 retire with mask command. 

1 8. The memory translation hub of claim 6 wherein the memory control packet 

2 specifies a memory row, and one of a broadcast flag and a memory bank 

3 address, if the memory control packet is the pre-charge command. 

1 9. The memory translation hub of claim 6 wherein the memory control packet 

2 specifies a memory row, an operation, and one of a broadcast flag and a 

3 memory bank address, if the memory control packet is the service command. 
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1 10. The memory translation hub of claim 9 wherein the operation is one of a no 

2 operation, refresh, self refresh entry, self refresh exit, power-down entry, 

3 power-down exit, clock stop, current calibrate and sample, and temperature 

4 calibrate. 

1 11. The memory translation hub of claim 2 further comprising a write logic circuit 

2 coupled to the memory channel interface and to the memory bus interface, 

3 the write logic circuit receiving a write data packet from the memory channel 

4 interface and causing the memory bus interface to provide memory control 

5 signals and data signals on the memory bus responsive to the write data 

6 packet, the memory channel interface receiving a write data packet only from 

7 the data portion of the memory channel. 

1 12. The memory translation hub of claim 2 further comprising a read logic circuit 

2 coupled to the memory channel interface and to the memory bus interface, 

3 the read logic circuit receiving read data from the memory bus interface, 

4 generating a read data packet containing the read data, and causing the 

5 memory channel interface to transmit the read data packet on the data 

6 portion of the memory channel. 

1 13. A memory translation hub comprising: 

2 means for receiving a memory control packet from a memory channel; 

3 means for translating the memory control packet to memory control signals; 

4 and 
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5 means for generating the memory control signals on a memory bus. 

1 14. The memory translation hub of claim 13 wherein the means for receiving a 

2 memory control packet further comprises means for receiving a memory 

3 control packet from a control portion of the memory channel responsive to the 

4 memory control packet. 

1 1 5. The memory translation hub of claim 14 further comprising: 

2 means for receiving a write data packet from a data portion of the memory 

3 channel; 

4 means for providing memory control signals and data signals on the memory 

5 bus responsive to the write data packet. 

1 16. The memory translation hub of claim 14 further comprising: 

2 means for receiving read data from the memory bus; 

3 means for generating a read data packet containing the read data; and 

4 means for transmitting the read data packet on a data portion of the memory 

5 channel. 

1 17. A method of connecting a memory bus to a memory controller hub through a 

2 memory channel comprising: 

3 receiving a memory control packet from the memory channel; 

4 translating the memory control packet to memory control signals; and 

5 generating the memory control signals on the memory bus. 
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1 1 8. The method of claim 1 7 further comprising: 

2 receiving a write data packet from the memory channel; and 

3 providing memory control signals and data signals on the memory bus 

4 responsive to the write data packet. 

1 19. The method of claim 17 further comprising: 

2 receiving read data from the memory bus interface; 

3 generating a read data packet containing the read data; and 

4 transmitting the read data packet on the memory channel. 

1 20. A memory subsystem comprising: 

2 a memory control hub; 

3 a memory channel coupled to the memory control hub; 

4 a memory bus; 

5 a memory device coupled to the memory bus; and 

6 a memory translation hub coupled to the memory channel and to the memory 

7 bus, the memory translation hub to receive a memory control packet 

8 from the memory channel, and to generate memory control signals on 

9 the memory bus responsive to the memory control packet. 

1 21 . The memory subsystem of claim 20 wherein the memory channel includes a 

2 control portion and a data portion, the memory translation hub receiving a 

3 memory control packet only from the control portion of the memory channel. 
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22. The memory subsystem of claim 21 wherein the memory translation hub 
further receives a write data packet from the data portion of the memory 
channel, and generates memory control signals and data signals on the 
memory bus responsive to the write data packet. 

23. The memory translation hub of claim 21 wherein the memory translation hub 
further receives read data from the memory bus interface, generates a read 
data packet containing the read data, and transmits the read data packet on 
the data portion of the memory channel. 
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ABSTRACT OF THE DISCLOSURE 



A memory translation hub comprising a memory channel interface, a memory 
bus interface, and a command generator coupled to the memory channel interface 
and to the memory bus interface. The memory channel interface receives a 
memory control packet from a memory channel. The memory bus interface 
provides a memory bus. The command generator causes the memory bus interface 
to provide memory control signals on the memory bus responsive to the memory 
control packet. 
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